<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" lang="zh" xml:lang="zh">
<head>
<META http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>任务描述符: 描述分发</title>
<meta content="TaskDescriptor" name="uma.type">
<meta content="describe_distribution" name="uma.name">
<meta content="描述分发" name="uma.presentationName">
<meta content="_dcpBoUocEdqrjq4i3fchvA" name="uma.guid">
<meta content="TaskDescriptor" name="element_type">
<meta content="description" name="filetype">
<meta name="role" content="软件设计人员">
<link type="text/css" href="./../../css/default.css" rel="StyleSheet">
<script language="JavaScript" type="text/javascript" src="./../../scripts/ContentPageResource.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/ContentPageSection.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/ContentPageSubSection.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/ActivityTreeTable.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/ProcessElementPage.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/ContentPageToolbar.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/contentPage.js"></script><script language="JavaScript" type="text/javascript" src="./../../scripts/processElementData.js"></script><script language="JavaScript" type="text/javascript">
					var defaultQueryStr = '?proc={002674F9-6511-4D15-8623-B761D8C48986}&path={002674F9-6511-4D15-8623-B761D8C48986},{F2160C54-F666-4736-9982-FC7F58F15FAD},_dcpBoUocEdqrjq4i3fchvA';
					var backPath = './../../';
					var imgPath = './../../images/';
					var nodeInfo=[{view: "view:_e_O28N7KEdm8G6yT7-Wdqw", path: ["_e_O28N7KEdm8G6yT7-Wdqw", "_vCtak0JHEdq4z9xc-r201w", "_vChNQkJHEdq4z9xc-r201w", "_vChNREJHEdq4z9xc-r201w", "_UNdM0CFtEdqrX8YVzvtlIg", "_dcpBoUocEdqrjq4i3fchvA"]}, {view: "view:_FCx1oN7CEdmsEI4YDGX2ag", path: ["_FCx1oN7CEdmsEI4YDGX2ag", "_PEpmMCVuEdqSZ9OimJ-AzA", "_-kFhcCVuEdqSZ9OimJ-AzA", "_pV4NgSFsEdqrX8YVzvtlIg", "_UNdM0CFtEdqrX8YVzvtlIg", "_dcpBoUocEdqrjq4i3fchvA"]}, {view: "view:_FCx1oN7CEdmsEI4YDGX2ag", path: ["_FCx1oN7CEdmsEI4YDGX2ag", "_e_O28N7KEdm8G6yT7-Wdqw", "_vCtak0JHEdq4z9xc-r201w", "_vChNQkJHEdq4z9xc-r201w", "_vChNREJHEdq4z9xc-r201w", "_UNdM0CFtEdqrX8YVzvtlIg", "_dcpBoUocEdqrjq4i3fchvA"]}];
					contentPage.preload(imgPath, backPath, nodeInfo, defaultQueryStr, true, true, false);
				</script>
</head>
<body>
<div id="breadcrumbs"></div>
<table width="100%" cellspacing="0" cellpadding="0" border="0">
<tr>
<td valign="top">
<div id="page-guid" value="_dcpBoUocEdqrjq4i3fchvA"></div>
<table width="100%" cellpadding="0" cellspacing="0" border="0">
<tr>
<td nowrap="true" class="pageTitle">任务：描述分发</td><td width="100%">
<div id="contentPageToolbar" align="right"></div>
</td>
</tr>
</table>
<table cellspacing="0" cellpadding="0" border="0" width="100%">
<tr>
<td class="pageTitleSeparator"><img height="1" title="" alt="" src="./../../images/shim.gif"></td>
</tr>
</table>
<div class="overview">
<table cellpadding="0" cellspacing="0" border="0" width="97%">
<tr>
<td width="50"><img title="" alt="" src="./../../images/taskdes_lg_dgm32.gif"></td><td>
<table cellpadding="0" cellspacing="0" border="0" class="overviewTable">
<tr>
<td valign="top">此任务通过物理节点及其互连定义了分布式系统的部署体系结构。</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
<div class="sectionHeading">用途</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr valign="top">
<td class="sectionTableSingleCell"><a id="Top" name="Top"></a> 
<div style="margin-left: 2em">
    描述系统功能在物理节点间是如何分布的。此任务仅适用于分布式系统。
</div></td>
</tr>
</table>
</div>
<div class="sectionHeading">关系</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr valign="top">
<th scope="row" class="sectionTableHeading">角色</th><td width="30%" class="sectionTableCell"><span class="sectionTableCellHeading">主要:
							</span>
<ul>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_software_architect_8B6C5D41.html" guid="_COWYtRi2Edq_uI8xTPML6g">软件设计人员</a>
</li>
</ul>
</td><td width="30%" class="sectionTableCell"><span class="sectionTableCellHeading">其他:
							</span></td><td class="sectionTableCell"><span class="sectionTableCellHeading">辅助:
							</span></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading">输入</th><td width="30%" class="sectionTableCell"><span class="sectionTableCellHeading">必需:
								</span>
<ul>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_software_architecture_document_7A057157.html" guid="_COWYthi2Edq_uI8xTPML6g">软件体系结构文档</a>
</li>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_design_model_84A35167.html" guid="_COWYtxi2Edq_uI8xTPML6g">设计模型</a>
</li>
</ul>
</td><td width="30%" class="sectionTableCell"><span class="sectionTableCellHeading">可选:
								</span>
<ul>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_supplementary_specification_4FFE3F60.html" guid="_COWYuRi2Edq_uI8xTPML6g">补充规范</a>
</li>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_deployment_model_45605F50.html" guid="_COWYuBi2Edq_uI8xTPML6g">部署模型</a>
</li>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_implementation_model_3E975376.html" guid="_COWYuhi2Edq_uI8xTPML6g">实施模型</a>
</li>
</ul>
</td><td class="sectionTableCell"><span class="sectionTableCellHeading">外部:
								</span>
<ul>
<li>无</li>
</ul>
</td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading">输出</th><td colspan="3" class="sectionTableCell">
<ul>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_deployment_model_45605F50.html" guid="_COWYuBi2Edq_uI8xTPML6g">部署模型</a>
</li>
<li>
<a href="./../../core.base_rup/capabilitypatterns/rup_software_architecture_document_7A057157.html" guid="_COWYthi2Edq_uI8xTPML6g">软件体系结构文档</a>
</li>
</ul>
</td>
</tr>
</table>
</div>
<div class="sectionHeading">主要描述</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr valign="top">
<td class="sectionTableSingleCell"><p>
    此任务通过物理节点及其互连定义了系统的部署体系结构。 在<a class="elementLinkWithUserText" href="./../../core.base_rup/tasks/architectural_analysis_2B9BE03.html" guid="{8CB48402-D4C5-4E17-BB33-507315CB1BBF}">任务：体系结构分析</a>过程中，定义了初始的<a class="elementLinkWithUserText" href="./../../core.base_rup/workproducts/rup_deployment_model_57DF1DF5.html" guid="{5981B6BE-2FD1-4984-AA94-2F7428439BA6}">部署模型</a>。在此任务中，对该部署模型（特别是<a class="elementLinkWithUserText" href="./../../core.base_rup/guidances/concepts/deployment_view_64CB74A6.html" guid="2.8416696002928195E-305">部署视图</a>）进行优化，以反映当前设计。
</p>
<p>
    在“精化”阶段早期，部署视图通常相当简略，但到了“精化”晚期，它应当是良好定义的。
</p></td>
</tr>
</table>
</div>
<div class="sectionHeading">步骤</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr>
<td class="sectionTableCell">
<div class="stepHeading"> 分析分布需求</div>
<div class="stepContent">
<table cellpadding="0" cellspacing="0" border="0" class="stepTable">
<tr valign="top">
<td><a id="Analyze Distribution Requirements" name="Analyze Distribution Requirements"></a>
<div align="left">
    <table border="1" width="100%" cellspacing="0" cellpadding="4" style="border: 1px solid rgb(128,128,128)"     bordercolorlight="#808080" bordercolordark="#808080">
        <tr>
            <td width="5%">
                <b>目的</b>
            </td>
            <td width="95%">
                定义系统分布要求达到什么程度。&nbsp;
            </td>
        </tr>
    </table><br />
</div>
<p>
    分布需求是由以下因素驱动的：
</p>
<ul>
    <li>
        <b>问题域中的分布需求（功能需求）</b>－ 可能存在以下显式需求：系统要访问或使用特定的分布式处理器、数据库或旧系统以执行其部分功能。
    </li>
    <li>
        <b>选择的部署配置</b> － 特定的部署配置通过定义节点的数目和类型及其互连，将约束施加于系统分布。例如，选择多层部署配置通常表示存在一个客户机节点、一个 Web 服务器节点和一个应用程序服务器节点。通常在<a class="elementLinkWithUserText" href="./../../core.base_rup/tasks/architectural_analysis_2B9BE03.html" guid="{8CB48402-D4C5-4E17-BB33-507315CB1BBF}">任务：体系结构分析</a>过程中选择特定的部署配置，并稍后在此任务中对其进行优化。
    </li>
    <li>
        <b>所需的资源（非功能需求）</b>－ 时间密集功能或计算密集功能可能需要特别装备的特定硬件配置以处理功能需求；例如，快速处理器、大量 RAM 或大量磁盘空间。该需求的一个示例是数字信号处理，它可能需要专门化的、专用的处理器。
    </li>
    <li>
        <b>容错需求</b> <b>（非功能需求）</b>－ 对备份处理器的需求。
    </li>
    <li>
        <b>可伸缩性和灵活性问题</b> <b>（非功能需求）</b>－ 任何单一的处理器都无法支持如此多的并发用户。会存在对系统功能进行负载均衡的需求，从而提供最高的性能和可伸缩性。
    </li>
    <li>
        <b>经济问题</b> － 在较大模型中，较小、较便宜的处理器的性价比不理想。
    </li>
</ul>
<p>
    对于众多的体系结构问题，这些需求某种程度上可能是互斥的。存在有冲突的需求，至少在初始阶段，并不罕见。根据需求的重要性对需求排序将有助于解决冲突。
</p></td>
</tr>
</table>
</div>
<div class="stepHeading"> 定义网络配置</div>
<div class="stepContent">
<table cellpadding="0" cellspacing="0" border="0" class="stepTable">
<tr valign="top">
<td><a id="XE_network_configuration__defining" name="XE_network_configuration__defining" class="index" key="网络配置（network configuration）" text="定义"></a><a id="Define the Network Configuration" name="Define the Network Configuration"></a>
<div align="left">
    <table border="1" width="100%" cellspacing="0" cellpadding="4" style="border: 1px solid rgb(128,128,128)"     bordercolorlight="#808080" bordercolordark="#808080">
        <tr>
            <td width="5%">
                <b>目的</b>
            </td>
            <td width="95%">
                定义网络配置与拓扑。&nbsp;
            </td>
        </tr>
    </table><br />
</div>
<p>
    在此步骤中，将对初始<a class="elementLinkWithUserText" href="./../../core.base_rup/workproducts/rup_deployment_model_57DF1DF5.html" guid="{5981B6BE-2FD1-4984-AA94-2F7428439BA6}">部署模型</a>（在<a class="elementLinkWithUserText" href="./../../core.base_rup/tasks/architectural_analysis_2B9BE03.html" guid="{8CB48402-D4C5-4E17-BB33-507315CB1BBF}">任务：体系结构分析</a>中定义）进行优化，以支持在<a href="#Analyze Distribution Requirements">上一步</a>中确定的分布需求。
</p>
<p>
    网络拓扑以及网络中处理器和设备的能力和特征将决定系统中可能的分布的性质和程度。
</p>
<p>
    需要捕获以下信息：
</p>
<ul>
    <li>
        网络的物理布局，包括位置
    </li>
    <li>
        网络中的节点及其配置和能力（配置包括安装在节点上的硬件和软件、处理器的数目、磁盘空间量、内存量、交换量等；其中，安装在节点上的硬件可用设备表示）
    </li>
    <li>
        网络中每个网段的带宽
    </li>
    <li>
        网络中任何冗余路径的存在（这将有助于提供容错能力）
    </li>
    <li>
        节点的主要用途，包括：
    </li>
    <li style="list-style: none">
        <ul>
            <li>
                用户使用的工作站节点
            </li>
            <li>
                可在其上进行无头处理的服务器节点（为了简化服务器配置，可以将服务器组件压缩为不含用户界面组件的无头映像）
            </li>
            <li>
                用于开发和测试的特殊配置
            </li>
            <li>
                其他专门化的处理器
            </li>
        </ul>
    </li>
    <li>
        若存在 IP 网络，则包括 IP 设计和设施（例如，DNS、VPN）
    </li>
    <li>
        因特网在解决方案中扮演的角色
    </li>
</ul>
<p class="exampleheading">
    示例
</p>
<p class="example">
    下图阐明了 ATM 的部署视图
</p>
<p align="center">
    <img src="./../../core.base_rup/tasks/resources/dist1.gif" alt="本图显示 ATM 的部署视图" width="594" height="456" />
</p>
<p class="picturetext">
    ATM 的部署视图
</p>
<p class="example">
    该图说明了两个节点（在该示例中作为重点的 ATM 本身）和 ATM 网络服务器，其中，所有至银行间网络的连接都是通过 ATM 网络服务器建立的。尽管 ATM 网络服务器处于 ATM
    构造器范围之外，但是在此显示该服务器以说明如何记录网络带宽。该图还显示了在 ATM 节点上执行的进程和线程，这将在下一步<a href="#Allocate System Elements to Nodes">将系统元素分配给节点</a>中进行讨论。
</p>
<p class="example">
    注意使用注释来记录处理器和网络容量。若图中未显示这样的记录，也可能是在节点（或设备）的文档字段显示它。
</p></td>
</tr>
</table>
</div>
<div class="stepHeading"> 将系统元素分配给节点</div>
<div class="stepContent">
<table cellpadding="0" cellspacing="0" border="0" class="stepTable">
<tr valign="top">
<td><a id="Allocate System Elements to Nodes" name="Allocate System Elements to Nodes"></a>
<div align="left">
    <table border="1" width="100%" cellspacing="0" cellpadding="4" style="border: 1px solid rgb(128,128,128)"     bordercolorlight="#808080" bordercolordark="#808080">
        <tr>
            <td width="5%">
                <b>目的&nbsp;</b>
            </td>
            <td width="95%">
                分配系统的工作负载。&nbsp;
            </td>
        </tr>
    </table><br />
</div>
<p>
    在该步骤中，系统元素被分配给在上一<a href="#Define the Network Configuration">步骤</a>中定义的节点。可从逻辑和物理的角度描述部署。
</p>
<p>
    <i>逻辑部署</i>中，逻辑元素（类、子系统或它们的实例）被映射到节点。其中可能包括<a class="elementLinkWithUserText" href="./../../core.base_rup/tasks/describe_runtime_architecture_2F8E190.html#IdentifyProcessesAndThreads" guid="{4D35C038-A2D0-48B8-9ECD-52717FEAE33A}">控制线程</a>。例如，逻辑部署可能声明：将 AuctionManager 子系统部署到应用程序服务器。
</p>
<p>
    <i>物理部署</i>中，文件被映射到节点。例如，物理部署可能声明：将 CloseAuctionTimer.class 文件部署到 server76。
</p>
<p>
    分布区域的总和可以且通常小于各部分的总和。 要使分布确实带来好处，需要执行工作并仔细规划。 当确定将哪些元素映射到哪些节点时，请考虑以下各项：
</p>
<ul>
    <li>
        节点容量（根据内存和处理能力）
    </li>
    <li>
        通信介质带宽（总线、LAN、WAN）
    </li>
    <li>
        硬件和通信链路的可用性，重新路由
    </li>
    <li>
        冗余及容错需求
    </li>
    <li>
        响应时间需求
    </li>
    <li>
        吞吐量需求
    </li>
</ul>
<p>
    基于使跨网络通信量最小化的目的，将元素分配给节点；应将大量交互的元素分配到相同的节点中；而交互频率较低的元素则可驻留在不同的节点中。至关重要的决策（有时需要迭代）是在何处划定界限。在两个或更多节点上分布进程将要求对系统中进程间通信模式进行周密的检查。通常存在一种天真的观点：处理的分布可从一台机器上卸下工作并转移给另一台机器。实际上，若未仔细考虑进程和节点边界，额外的进程间通信工作负载将轻易地抵消由于工作负载分布而产生的所有好处。
</p>
<p class="exampleheading">
    示例
</p>
<p class="example">
    上一示例图 <b>ATM 的部署视图</b>，说明了将进程分配给 ATM 节点。存在单个进程（ATM 主程序），它又由三个独立的控制线程（客户接口、ATM 网络接口和设备控制器）组成。
</p>
<p>
    某些环境提供了自动化和／或简化分布的机制。例如：
</p>
<ul>
    <li>
        <b>群集：</b>群集是一组作为单元的服务器，一般包括诸如故障转移和负载均衡等功能。在此情况下，部署视图应描述是如何将系统元素分配给群集的，以及如何配置群集以将其映射到物理节点。
    </li>
    <li>
        <b>容器：</b>在组件环境中，例如 J2EE、Microsoft .NET
        等，组件将在名为容器的逻辑计算环境中执行。可将容器看作是“逻辑节点”。部署视图应描述是如何将系统元素部署到容器的，接着描述是如何将容器分配给物理节点的。
    </li>
</ul>
<p>
    应将此类支持性分布机制的应用以及需要如何配置它们并映射到物理节点以满足分布需求作为部署视图的一部分加以记录。<br />
    <br />
</p></td>
</tr>
</table>
</div>
</td>
</tr>
</table>
</div>
<div class="sectionHeading">属性</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_多次出现" abbr="多次出现">多次出现</th><td align="left" class="sectionTableCell" headers="property_多次出现"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_事件驱动" abbr="事件驱动">事件驱动</th><td align="left" class="sectionTableCell" headers="property_事件驱动"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_正在进行" abbr="正在进行">正在进行</th><td align="left" class="sectionTableCell" headers="property_正在进行"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_可选" abbr="可选">可选</th><td align="left" class="sectionTableCell" headers="property_可选"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_已计划" abbr="已计划">已计划</th><td align="left" class="sectionTableCell" headers="property_已计划"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading" id="property_可重复" abbr="可重复">可重复</th><td align="left" class="sectionTableCell" headers="property_可重复"><img title="" alt="" height="15" width="20" src="./../../images/indent.gif"></td>
</tr>
</table>
</div>
<div class="sectionHeading">更多信息</div>
<div class="sectionContent">
<table cellpadding="0" cellspacing="0" border="0" class="sectionTable">
<tr valign="top">
<th scope="row" class="sectionTableHeading">概念</th><td class="sectionTableCell">
<ul>
<li>
<a href="./../../core.base_rup/guidances/concepts/distribution_patterns_5A01CAF5.html" guid="6.137181182978733E-305">分布模式</a>
</li>
</ul>
</td>
</tr>
<tr valign="top">
<th scope="row" class="sectionTableHeading">工具向导</th><td class="sectionTableCell">
<ul>
<li>
<a href="./../../core.base_rup/guidances/toolmentors/document_deployment_model_56B174AC.html" guid="{76E85375-118B-4901-B80C-94B4A008EBA5}">使用 Rational Rose 记录部署模型</a>
</li>
<li>
<a href="./../../core.base_rup/guidances/toolmentors/describing_distribution_7274AD7.html" guid="{F4759F41-D90B-4587-8DE0-3453FBFB5188}">使用 Rational XDE Developer 描述分发</a>
</li>
</ul>
</td>
</tr>
</table>
</div>
<table cellpadding="0" cellspacing="0" border="0" class="copyright">
<tr>
<td class="copyright"><p>
    &copy; &nbsp;Copyright IBM Corp.&nbsp;1987, 2006. &nbsp;All Rights Reserved.
</p></td>
</tr>
</table>
</td>
</tr>
</table>
</body>
<script type="text/javascript" language="JavaScript">
					contentPage.onload();
					contentPage.processPage.fixDescriptorLinks();
				</script>
</html>
